import { createApp } from 'vue'

import Cookies from 'js-cookie'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import 'element-plus/theme-chalk/dark/css-vars.css'
import locale from 'element-plus/es/locale/lang/zh-cn'

import '@/assets/styles/index.scss'

import App from './App'
import store from './store'
import router from './router'
import directive from './directive'

// 注册指令
import plugins from './plugins'
import { download } from '@/utils/request'

// svg图标
import 'virtual:svg-icons-register'
import SvgIcon from '@/components/SvgIcon'
import elementIcons from '@/components/SvgIcon/svgicon'

import './permission'

import { useDict } from '@/utils/dict'
import {
  parseTime,
  resetForm,
  addDateRange,
  handleTree,
  selectDictLabel,
  selectDictLabels,
} from '@/utils/ruoyi'

// 分页组件
import Pagination from '@/components/Pagination'

// 自定义表格工具组件
import RightToolbar from '@/components/RightToolbar'

// 富文本组件
import Editor from '@/components/Editor'

// 文件上传组件
import FileUpload from '@/components/FileUpload'

// 图片上传组件
import ImageUpload from '@/components/ImageUpload'

// 图片预览组件
import ImagePreview from '@/components/ImagePreview'

// 字典标签组件
import DictTag from '@/components/DictTag'

const app = createApp(App)

// 全局方法挂载
app.config.globalProperties.useDict = useDict
app.config.globalProperties.download = download
app.config.globalProperties.parseTime = parseTime
app.config.globalProperties.resetForm = resetForm
app.config.globalProperties.handleTree = handleTree
app.config.globalProperties.addDateRange = addDateRange
app.config.globalProperties.selectDictLabel = selectDictLabel
app.config.globalProperties.selectDictLabels = selectDictLabels

// 全局组件挂载
app.component('dict-tag', DictTag)
app.component('pagination', Pagination)
app.component('file-upload', FileUpload)
app.component('image-upload', ImageUpload)
app.component('image-preview', ImagePreview)
app.component('right-toolbar', RightToolbar)
app.component('editor', Editor)

app.use(router)
app.use(store)
app.use(plugins)
app.use(elementIcons)
app.component('svg-icon', SvgIcon)

directive(app)

import dragScroll from 'drag-scroll-vue3'
app.directive('drag-scroll', dragScroll)

// 自定义指令 v-resize-rf
// 监听元素宽高变化
// <div id="resize" v-resize-rf="getData">
import useResize from 'v-resize-rf'
app.use(useResize)

// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
  locale: locale,

  // 支持 large、default、small
  size: Cookies.get('size') || 'default',
})

app.mount('#app')
